草庐IT

C++ 性能 std::array 与 std::vector

全部标签

windows - 使用 boost::filesystem::path 作为 std::map 中的键

所以std::map想要对键类型进行排序,但我遇到了问题:"a/b""a/b"如何规范化路径以创建排序?这可能吗?我尝试在自定义比较运算符中使用path::generic_string(),但没有成功。fs::equivalent()也无济于事,因为实现平等对于std::map来说还不够,它需要一个排序。这也是为什么这个问题不是HowdoI"normalize"apathnameusingboost::filesystem?的重复问题的原因。.上下文:仅限Windows,Boost1.49,文件系统3。 最佳答案 要使路径具有可比性

c++ - 使用平假名将 std::wstring 转换为 QString

我正在尝试将包含平假名的文本从wstring转换为QString,以便它可以用于标签的文本属性。但是,我的代码无法正常工作,我不确定这是为什么。下面的转换方式明显告诉我我做错了:std::wstringmyWString=L"SomeHiragana:あいうえお";ui->label->setText(QString::fromStdWString(myWString));输出:一些平假名:ã‚ã„ã†ãˆãŠ如果我直接把它们放在字符串中,我可以在标签上打印平假名:ui->label->setText("SomeHiragana:あいうえお");输出:一些平假名:あいうえお这意味着我可

arrays - 如何使用批处理在数组(for 循环)中一次处理两个元素?

我正在尝试为传递到我的脚本中的参数创建某种处理程序。这个想法是一起处理“成对”的参数。所以,也就是说1和2、3和4、5和6,等等……(不是2和3、4和5、6和7,等等…….)我认为批处理非常酷,但我对批处理还很陌生。我不知道该怎么做。到目前为止,我已经成功地使用以下脚本将参数放入数组中:SETLOCALEnableDelayedExpansionset/acount+=1set"params[%count%]=%~1"shiftifdefinedparams[%count%](goto:repeat)else(set/acount-=1)现在我只需要成对处理每个元素。我根本不知道该怎么

c# - 为 .NET 应用启用高性能 GPU

用户提示我的应用程序(使用Direct3D11渲染一些重型3D内容以获得类似CAD的功能)在双GPU系统上的IntelGPU上运行。发现NvOptimusEnablement/AmdPowerXpressRequestHighPerformance导出了变量。但是,该应用程序有.NET前端,无法从那里导出内容。同时there’ssomeworkaround,重新编译步骤会破坏调试器(不能再设置断点)并使调试符号无效,我需要它们都可靠地工作。还有其他想法吗?是否可以在安装时创建nVidia应用程序配置文件?或者,如何使用NVApi来选择高性能GPU? 最佳答案

.net - "Largest free region"的性能计数器?

我正在调试内存不足的异常。当我得到异常时,“虚拟字节”性能计数器指示有足够的​​可寻址空间。然而,问题在于可寻址空间碎片化严重,并且“最大空闲区域”(从WinDbg中的!address返回)太小。为了测量内存碎片,我想在perfmon中监控“最大空闲区域”。是否有一个性能计数器可以给我这个值? 最佳答案 我不相信这条信息有一个单独的性能计数器,但可以使用VirtualQueryExWin32函数推导出来。您可以在最小有效虚拟地址(可以从GetSystemInfo获得)上调用它,然后您可以使用返回的页面范围的大小来确定下一个页面范围的

.net - DataGridView 性能 - 是否取决于视频卡?

我有一个C#/.Net应用程序,它似乎使用大部分CPU时间来更新DataGridView。我大约每1.5秒手动更新一次数据,只更新已更改的数据。这最终是每1.5秒大约250次更新。我想将这1.5秒减少到更小的数字(可能是0.5秒)。我已经尽可能多地分析和优化,虽然性能还可以,但我希望它更快。我的问题是,将视频卡从NvidiaFX1800升级到NvidiaFX3800会产生显着的加速吗? 最佳答案 GDI+操作不太依赖于图形CPU,因为它仅使用每个图形卡都支持的基本加速操作(线条、矩形等)。我猜这里的问题是您在更新期间没有“隐藏”控制

c++ - 在非托管代码中创建和更新性能计数器的好引用是什么?

我有几个应用程序需要创建和写入性能计数器。其中之一是用C++编写的。目前,无法将该应用程序升级到.NET。哪里有使用非托管代码访问性能计数器的好资源?谢谢! 最佳答案 从这里开始:http://msdn.microsoft.com/en-us/library/aa373209(v=VS.85).aspx请注意,您如何发布数据取决于您的操作系统:http://msdn.microsoft.com/en-us/library/aa373165(v=VS.85).aspx 关于c++-在非托管

windows - cmd 相当于 std::string::find_first:of

C++、Java、JavaScript和其他可能的编程语言都有一个字符串函数,可以在字符串中搜索指定字符串模式中的任何字符。例如,C++的std::string::find_first_of像这样工作:std::coutCMD中是否有任何等效项?我尝试搜索“dos字符串函数”,但似乎找不到任何内容。 最佳答案 没有直接的方法,但您可以很容易地编写自己的方法。搜索一个字符@echooffcall:charposition"Searchmeforvowels"aposechoFoundaatposition%pos%goto:eof:c

arrays - 如何从文本文件中获取字符串到批处理文件中的数组?

我有这样一个文本文件我的文件.txt:applebananagrapes我想将文本文件拖到批处理文件中并将变量设置到这样的数组中:array[0]=applearray[1]=bananaarray[2]=grapes但我做不到。我的问题不仅仅是打印它们,但我什至不能那样做。我将在批处理文件的其余部分执行解析操作。我的代码:@echooffsetlocalEnableDelayedExpansionseti=0for/f%%ain%1do(set/ai+=1setarray[!i!]=!a!)echo%array[0]%echo%array[1]%echo%array[2]%endlo

c++ - boost::interprocess_mutex 与 Win32 native 互斥锁的性能如何?

请注意,我可以在boost源代码中进行研究,如果没有人提供答案,我可能会这样做来回答我自己的好奇心。但是我确实会问,因为也许有人已经做过这种比较并且可以权威地回答?似乎在进程之间创建一个共享内存映射文件,并通过使用InterlockedIncrement()构造,可以创建一个类似于CRITICAL_SECTION的主要用户模式互斥体,它在进程间同步方面比Win32Mutex性能要好得多。所以我的期望是,boost::interprocess_mutex的Win32实现可能会以这种方式实现,并且比本地API产品快得多。不过我只是有一个假设,我不知道通过现场测试boost::interpr